﻿using Grand.Domain.Common;
using Grand.Domain.Configuration;

namespace Grand.Domain.Tax;

public class TaxSettings : ISettings
{
    /// <summary>
    ///     Tax based on
    /// </summary>
    public TaxBasedOn TaxBasedOn { get; set; }

    /// <summary>
    ///     Tax display type
    /// </summary>
    public TaxDisplayType TaxDisplayType { get; set; }

    /// <summary>
    ///     Gets or sets default address used for tax calculation
    /// </summary>
    public Address DefaultTaxAddress { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether each tax rate should be displayed on separate line (shopping cart page)
    /// </summary>
    public bool DisplayTaxRates { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether prices incude tax
    /// </summary>
    public bool PricesIncludeTax { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether customers are allowed to select tax display type
    /// </summary>
    public bool AllowCustomersToSelectTaxDisplayType { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether to hide zero tax
    /// </summary>
    public bool HideZeroTax { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether to hide tax in order summary when prices are shown tax inclusive
    /// </summary>
    public bool HideTaxInOrderSummary { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether we should always exclude tax from order subtotal (no matter of selected tax
    ///     dispay type)
    /// </summary>
    public bool ForceTaxExclusionFromOrderSubtotal { get; set; }


    /// <summary>
    ///     Gets or sets a default tax category identifier for products
    /// </summary>
    public string DefaultTaxCategoryId { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether shipping price is taxable
    /// </summary>
    public bool ShippingIsTaxable { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether shipping price incudes tax
    /// </summary>
    public bool ShippingPriceIncludesTax { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating the shipping tax category identifier
    /// </summary>
    public string ShippingTaxCategoryId { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether payment method additional fee is taxable
    /// </summary>
    public bool PaymentMethodAdditionalFeeIsTaxable { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether payment method additional fee incudes tax
    /// </summary>
    public bool PaymentMethodAdditionalFeeIncludesTax { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating the payment method additional fee tax class identifier
    /// </summary>
    public string PaymentMethodAdditionalFeeTaxCategoryId { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether EU VAT (Eupore Union Value Added Tax) is enabled
    /// </summary>
    public bool EuVatEnabled { get; set; }

    /// <summary>
    ///     Gets or sets a shop country identifier
    /// </summary>
    public string EuVatShopCountryId { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether this store will exempt eligible VAT-registered customers from VAT
    /// </summary>
    public bool EuVatAllowVatExemption { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether we should use the EU web service to validate VAT numbers
    /// </summary>
    public bool EuVatUseWebService { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating whether VAT numbers should be automatically assumed valid
    /// </summary>
    public bool EuVatAssumeValid { get; set; }

    /// <summary>
    ///     Gets or sets a value indicating for rounding calulate price
    /// </summary>
    public int CalculateRoundPrice { get; set; } = 2;

    public MidpointRounding MidpointRounding { get; set; } = MidpointRounding.ToEven;
}